home *** CD-ROM | disk | FTP | other *** search
/ STraTOS 1997 April & May / STraTOS 1 - 1997 April & May.iso / CD01 / INTERNET / SITES / LITTLE / P3SRC.ZIP / ATARI / HCMPLX.H < prev    next >
Encoding:
C/C++ Source or Header  |  1996-02-07  |  4.1 KB  |  85 lines

  1. /****************************************************************************
  2. *                   hcmplx.h
  3. *
  4. *  This module contains all defines, typedefs, and prototypes for HCMPLX.C.
  5. *
  6. *  from Persistence of Vision(tm) Ray Tracer
  7. *  Copyright 1996 Persistence of Vision Team
  8. *---------------------------------------------------------------------------
  9. *  NOTICE: This source code file is provided so that users may experiment
  10. *  with enhancements to POV-Ray and to port the software to platforms other
  11. *  than those supported by the POV-Ray Team.  There are strict rules under
  12. *  which you are permitted to use this file.  The rules are in the file
  13. *  named POVLEGAL.DOC which should be distributed with this file. If
  14. *  POVLEGAL.DOC is not available or for more info please contact the POV-Ray
  15. *  Team Coordinator by leaving a message in CompuServe's Graphics Developer's
  16. *  Forum.  The latest version of POV-Ray may be found there as well.
  17. *
  18. * This program is based on the popular DKB raytracer version 2.12.
  19. * DKBTrace was originally written by David K. Buck.
  20. * DKBTrace Ver 2.0-2.12 were written by David K. Buck & Aaron A. Collins.
  21. *
  22. *****************************************************************************/
  23.  
  24. #ifndef HCMPLX_H
  25. #define HCMPLX_H
  26.  
  27. /*****************************************************************************
  28. * Global preprocessor defines
  29. ******************************************************************************/
  30.  
  31. /*****************************************************************************
  32. * Global typedefs
  33. ******************************************************************************/
  34.  
  35. /*****************************************************************************
  36. * Global variables
  37. ******************************************************************************/
  38.  
  39. /*****************************************************************************
  40. * Global functions
  41. ******************************************************************************/
  42.  
  43. int F_Bound_HCompl PARAMS((RAY *, FRACTAL *, DBL *, DBL *));
  44. void Normal_Calc_HCompl PARAMS((VECTOR, int, FRACTAL *));
  45. int Iteration_HCompl PARAMS((VECTOR, FRACTAL *));
  46. int D_Iteration_HCompl PARAMS((VECTOR, FRACTAL *, DBL *));
  47.  
  48. int F_Bound_HCompl_z3 PARAMS((RAY *, FRACTAL *, DBL *, DBL *));
  49. void Normal_Calc_HCompl_z3 PARAMS((VECTOR, int, FRACTAL *));
  50. int Iteration_HCompl_z3 PARAMS((VECTOR, FRACTAL *));
  51. int D_Iteration_HCompl_z3 PARAMS((VECTOR, FRACTAL *, DBL *));
  52.  
  53. int F_Bound_HCompl_Reciprocal PARAMS((RAY *, FRACTAL *, DBL *, DBL *));
  54. void Normal_Calc_HCompl_Reciprocal PARAMS((VECTOR, int, FRACTAL *));
  55. int Iteration_HCompl_Reciprocal PARAMS((VECTOR, FRACTAL *));
  56. int D_Iteration_HCompl_Reciprocal PARAMS((VECTOR, FRACTAL *, DBL *));
  57.  
  58. int F_Bound_HCompl_Func PARAMS((RAY *, FRACTAL *, DBL *, DBL *));
  59. void Normal_Calc_HCompl_Func PARAMS((VECTOR, int, FRACTAL *));
  60. int Iteration_HCompl_Func PARAMS((VECTOR, FRACTAL *));
  61. int D_Iteration_HCompl_Func PARAMS((VECTOR, FRACTAL *, DBL *));
  62.  
  63. void Complex_Exp PARAMS((CMPLX *target, CMPLX *source));
  64. void Complex_Log PARAMS((CMPLX *target, CMPLX *source));
  65. void Complex_Sin PARAMS((CMPLX *target, CMPLX *source));
  66. void Complex_ASin PARAMS((CMPLX *target, CMPLX *source));
  67. void Complex_Sinh PARAMS((CMPLX *target, CMPLX *source));
  68. void Complex_ASinh PARAMS((CMPLX *target, CMPLX *source));
  69. void Complex_Cos PARAMS((CMPLX *target, CMPLX *source));
  70. void Complex_ACos PARAMS((CMPLX *target, CMPLX *source));
  71. void Complex_Cosh PARAMS((CMPLX *target, CMPLX *source));
  72. void Complex_ACosh PARAMS((CMPLX *target, CMPLX *source));
  73. void Complex_Tan PARAMS((CMPLX *target, CMPLX *source));
  74. void Complex_ATan PARAMS((CMPLX *target, CMPLX *source));
  75. void Complex_Tanh PARAMS((CMPLX *target, CMPLX *source));
  76. void Complex_ATanh PARAMS((CMPLX *target, CMPLX *source));
  77. void Complex_Sqrt PARAMS((CMPLX *target, CMPLX *source));
  78. void Complex_Pwr PARAMS((CMPLX *target, CMPLX *source));
  79.  
  80. void Complex_Mult PARAMS((CMPLX *target, CMPLX *source1, CMPLX *source2));
  81. void Complex_Div PARAMS((CMPLX *target, CMPLX *source1, CMPLX *source2));
  82. void Complex_Power PARAMS((CMPLX *target, CMPLX *source1, CMPLX *source2));
  83.  
  84. #endif
  85.